Abs
对输入数组逐元素计算绝对值。
对于实数类型,返回其数值的绝对值; 对于复数类型,返回其模长。
\[\begin{split}dst_i =
\begin{cases}
|src_i|, & \text{实数类型} \\
\sqrt{\Re(src_i)^2 + \Im(src_i)^2}, & \text{复数类型}
\end{cases}\end{split}\]
- 输入:
src_data - 输入数据地址。
length - 计算长度。
core_mask - 核掩码(仅适用于共享存储版本)。
- 输出:
dst_data - 计算结果地址。
- 支持平台:
FT78NEMT7004
备注
FT78NE 支持 fp, dp, int8, int16, int32, cplx64, cplx128
MT7004 支持 hp, fp, int16, int32, cplx64
对于整数类型,结果为对应数值的绝对值
对于复数类型,输出为模长(实数)
共享存储版本:
-
void i8_abs_s(int8_t *src_data, int8_t *dst_data, int length, int core_mask)
-
void i16_abs_s(int16_t *src_data, int16_t *dst_data, int length, int core_mask)
-
void i32_abs_s(int32_t *src_data, int32_t *dst_data, int length, int core_mask)
-
void hp_abs_s(half *src_data, half *dst_data, int length, int core_mask)
-
void fp_abs_s(float *src_data, float *dst_data, int length, int core_mask)
-
void dp_abs_s(double *src_data, double *dst_data, int length, int core_mask)
-
void c64_abs_s(float *src_data, float *dst_data, int length, int core_mask)
-
void c128_abs_s(double *src_data, double *dst_data, int length, int core_mask)
C调用示例:
1//FT78NE示例
2#include <stdio.h>
3#include <abs.h>
4
5int main(int argc, char* argv[]) {
6 float *input0 = (float *)0xA0000000; // input在DDR空间
7 float *output = (float *)0xC0000000;
8 int length = 1024;
9 int core_mask = 0xff;
10
11 fp_abs_s(input0, output, length, core_mask);
12 return 0;
13}
私有存储版本:
-
void i8_abs_p(int8_t *src_data, int8_t *dst_data, int length)
-
void i16_abs_p(int16_t *src_data, int16_t *dst_data, int length)
-
void i32_abs_p(int32_t *src_data, int32_t *dst_data, int length)
-
void hp_abs_p(half *src_data, half *dst_data, int length)
-
void fp_abs_p(float *src_data, float *dst_data, int length)
-
void dp_abs_p(double *src_data, double *dst_data, int length)
-
void c64_abs_p(float *src_data, float *dst_data, int length)
-
void c128_abs_p(double *src_data, double *dst_data, int length)
C调用示例:
1//FT78NE示例
2#include <stdio.h>
3#include <abs.h>
4
5int main(int argc, char* argv[]) {
6 float *input0 = (float *)0x10810000; // input在L2空间
7 float *output = (float *)0x10820000;
8 int length = 1024;
9
10 fp_abs_p(input0, output, length);
11 return 0;
12}